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(S) Robot control system. 

(57) A control system for an industrial robot adap- 
ted for storage of user programs which com- 
prise a series of robot instructions. At least one 
of the robot instructions is arranged as a shell 
instruction, which constitutes a call to a shell 
routine (20). The shell routine is associated with 
a plurality of optional attributes (21a, 21b, 21c) 
and comprises 

— a forward list (22) comprising a first set of 
robot instructions ; and 

— a backward list (23) comprising a second 
set of robot instructions. 

The control system comprises a program 
executor adapted, for forward running of a user 
program, to execute the shell instructions in 
accordance with the forward list and, for run- 
ning the user program backwards, to execute 
the shell instructions in accordance with the 
backward list 

The invention comprises a method for con- 
trolling an industrial robot with the control 
system according to the invention. This method 
comprises creating a plurality of shell routines 
and testing them in advance. When producing 
user programs, shell instructions are used 
which constitute calls to the shell routines 
created in advance. The user programs are 
executed by the program executor, and for 
forward running the shell instructions are car- 
ried out in accordance with the forward list, and 
for backward running the shell instructions are 
carried out in accordance with the backward 
list. 
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TECHNICAL FIELD 

The present invention relates to a control system for an industrial robot according to the precharacterising 
part of claim 1 and to a method for controlling an industrial robot comprising such a control system. 

5 

BACKGROUND ART 

When an industrial robot is to be put into operation for a certain task, for example spot welding, it must be 
programmed to carry out the task. During spot welding the robot is to move in the fastest possible way between 

10 a large number of fixed points and, at each point, carry out a welding operation. To have a starting point for 
the programming of the robot, the positions of the welding points are calculated in advance. However, this cal- 
culation only provides a rough estimate of the accurate positions of the points. A robot program for spot welding 
comprises a series of robot instructions which instruct the robot as to what points to move to, how it should 
move between the points, and what to do at the points. Before it is possible to start using the robot program, 

15 it has to be test-run. A number of things have to be corrected in the robot program before it is finished, for ex- 
ample the positions of the points and the speed at which the robot is to move between the points. During the 
test run the robot program is stepped such that one instruction at a time can be test run. After carrying out a 
change in a robot instruction, the robot program must be capable of being reversed such that the changed in- 
struction can be test run again. Repeated changes in the instruction may be needed before it is approved. 

20 To make it simple to try out a finished robot program, it is a requirement for the robot program to be able 

to be run step-by-step both in the forward and the backward direction. When a robot instruction is run back- 
wards, it is not always to carry out the same operation as when it is run forwards. In, for example, spot welding, 
a welding instruction which is run forwards may comprise the following steps: 
1) open welding gun, 

25 2) move robot to next given point, 

3) close welding gun, 

4) weld. 

If the same welding instruction is run backwards, it is to comprise the following steps: 

1) open welding gun, 
30 2) move robot back to preceding point 

The above example shows that when reversing an instruction, it does not function merely to carry out the 
steps of the instruction in the reverse order, but a completely different set of step instructions are needed for 
running backwards. 

When programming an industrial robot, usually some form of robot language is used. The robot language 
35 is formed such that it is simple to use for the robot user, who may be a person without knowledge or experience 
of programming. An instruction in the robot language, a robot instruction, consists of a call to a routine which 
comprises a set of instructions written in some programming language. The traditional way of developing a 
robot language means that the robot manufacturer himself develops the robot language while using a general 
high-level language. A robot instruction then consists of a call to a set of instructions written in the high-level 
40 language. Developing a robot instruction in high-level language, a so-called fixed robot instruction, requires 
on the one hand a programmer with sufficient knowledge of the high-level language, and on the other hand 
that the developed instruction is carried out in a system development environment on an external computer. 
A fixed robot instruction is supplied by the robot manufacturer, and it cannot be changed by a robot user who 
has neither knowledge of the high-level language nor access to the external computer. 
45 A robot is used in a wide variety of applications, for example spray-painting, welding, and assembly. Each 

application has its specific need of robot instructions. It is impossible for the robot manufacturer to develop 
robot instructions for all of these different needs. It is, therefore, desirable both for the robot manufacturer and 
the robot user to be able to develop new robot instructions in a simple way without having to use traditional 
system development 

50 

SUMMARY OF THE INVENTION, ADVANTAGES 

The object of the invention is to develop a robot control system which enables a person without knowledge 
of high-level programming and without access to an external computer to obtain new robot instructions in a 
55 rapid and simple manner. The invention further aims at developing a method for controlling an industrial robot 
comprising a control system according to the invention. 

To achieve this aim the invention suggests a robot control system according to the introductory part of 
claim 1 , which is characterized by the features of the characterizing part of claim 1 . 
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Further developments of the control system are characterized by the features of the additional claims 2 

to 4. 

A method for controlling an industrial robot with a control system according to the invention is characterized 
by the features of claim 5. 

5 According to the invention the control system comprises a program storage which is adapted for storage 

of user programs which comprise a series of robot instructions at least of which is arranged as a so-called shell 
routine. The shell routine is associated with a number of optional attributes and comprises 

- a forward list, i.e. an instruction sequence, comprising a first set of robot instructions; and 

- a backward list comprising a second set of robot instructions. 

10 The control system also comprises a program executor which is adapted, for forward running of a user 
program comprising so-called shell instructions, to execute the shell instructions in accordance with the for- 
ward list, and, for running the user program backwards, to execute the shell instructions in accordance with 
the backward list 

The method according to the invention entails creating and testing a number of shell routines in advance. 
15 The finished shell routines are stored in the program storage. When producing user programs, shell instructions 
are used which constitute calls to the shell routines created in advance. The user programs are executed by 
the program executor, and when running forwards, the shell instructions are executed in accordance with the 
forward list and when running backwards, the shell instructions are executed in accordance with the backward 
list 

20 Ashell instruction is a robot instruction which, instead of constituting a call to a series of instructions written 

in a high-level language, constitute a call to a series of instructions written in the robot language itself. One 
advantage of the invention is that the robot users themselves may develop their own instructions and that the 
robot manufacturer can supply instructions in which the user himself can make changes. 

The invention also facilitates the production of fixed routines, since a prototype can first be developed and 
25 test run as a shell routine and then, when it functions, be rewritten as a fixed routine. 

The optional attribute may be set such that a shell routine behaves just like a fixed routine. An operator 
running a user program will not notice any difference when running a shell instruction compared with when 
running a fixed robot instruction. 



30 BRIEF DESCRIPTION OF THE DRAWINGS 



Figure 1 schematically shows an industrial robot to which the invention may be applied. 
Figure 2 schematically shows part of a control system according to the invention. 
Figure 3 shows an example of a shell routine. 
35 Figure 4 shows in the form of a flow diagram an example of how the program executor executes a shell 
routine. 

Figure 5 schematically shows the configuration of a robot program with fixed instructions and shell in- 
structions. 

Figure 6 shows an example of a plurality of shell routines which have been brought together into a module, 
40 with attributes common to these shell routines. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 



Figure 1 shows an example of a known industrial robot. The mechanical part of the robot comprises a fixed 
45 bottom plate 1, in relation to which the lower part 2 of the robot is rotatable about a vertical axis. The lower 
arm 3 of the robot is rotatable in relation to the lower part 2 about a horizontal axis. The upper arm 4 of the 
robot is rotatable in relation to the lower arm about a second horizontal axis. The upper robot arm 4 consists 
of two parts 4a and 4b, the outer part 4b being rotatable in relation to the inner part 4a about a rotary axis 
coinciding with the longitudinal axis of the upper arm. At the outer end of the upper arm 4, the hand 5 of the 
so robot is mounted, which may be rotatable in, for example, two or three degrees of freedom in relation to the 
upper arm 4. A working tool 6 is attached to the robot hand, and as schematically shown in the figure this work- 
ing tool may consist of a gripper, or alternatively a welding device, a glue gun, or a measuring tool. The mech- 
anical part of the robot is connected, via a cable, to the control system 7 which comprises the electronic, com- 
puter, and drive equipment which is required for control of the mechanical part of the robot The control unit is 
55 connected to a programming unit 8 for programming and other operation of the robot 

Figure 2 shows those parts of the control system 7 which are of interest to the invention. A user program 
comprises a set of robot instructions. According to the invention, a robot instruction may be of two types, fixed 
robot instructions and so-called shell instructions. The fixed robot instructions consist of calls to fixed routines, 
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which comprise a set of instructions written in a general high-level language, for example C or Pascal. A fixed 
routine is developed and translated into machine code in an external computer, whereupon it is stored in an 
application library 10. Shell instructions consist of calls to so-called shell routines, which comprise a set of robot 
instructions. A shell routine is translated into an intermediate code by a compiler 12 and is then stored in the 
s program storage 11 . In the same way, a user program is translated by the compiler and stored into the program 
storage. The user program is executed by a program executor 13. Depending on the type of instruction that 
is to be executed, the program executor retrieves routines from the application library or from the program 
storage. The programming unit 8 is provided with a button 14 for setting the program to run forwards or back- 
wards. 

w The tasks of a robot user can be divided into two groups, namely, those of a program preparer and those 

of an operator. The tasks of the program preparer are, among other things, to develop new user programs and 
to make changes in existing programs before new applications. The tasks of the operator mainly comprise run- 
ning the user programs, for example, starting, stopping and reversing them, and to make minor changes in the 
programs. The program preparer and the operator are normally different persons. In those cases when the 

15 program preparer and the operator are not the same person, it is important that all the robot instructions behave 
in the same way to the operator, irrespective of whether they are developed in the traditional way or written 
in the robot language itself. 

One condition for the invention to be applicable to a robot is that the robot has a robot language which 
allows procedure calls with arguments, and that it is possible to link attributes to procedures. An attribute is a 

20 property which may be imparted to the shell routine, and each attribute may be switched on or off, i.e. activated 
or deactivated as required. Usually, the attributes are switched off during development and testing of the rou- 
tine, that is, as long as there is a need to make a change in the routine. When the routine is considered to be 
finished, the attributes are switched on. One important property of a shell instruction is that an operator who 
is running a user program does not notice any difference between a shell routine and a fixed robot instruction. 

25 To obtain this, the shell routine must be provided with two important attributes, namely, "view-only" and 

"no-step in". If the attribute "view-only" is switched on, this means that the shell routine can only be read, that 
is, it is not allowed to make changes in it The second attribute, "no-step-in", means that the shell routine be- 
haves as a coherent instruction and not as the sequence of instructions which it actually is. If the shell instruc- 
tion is part of a user program, the shell routine is concealed to the user. When, for example, stepping the user 

30 program, no stepping in the shell routine's lists is performed if the "no-step-in" attribute is switched on, but 
the stepping only takes place in the robot instructions of the user program itself. When both of these attributes 
are switched on, the operator notices no difference between a shell instruction and a fixed robot instruction. 

Figure 3 shows an example of a shell routine 20 with two attributes. The first attribute 21a consists of 
"view-only" (VO) and the second attribute 21b is "no-step-in" (NSI). Each shell routine has an individual name. 

35 The shell routine in Figure 3 has the name SWELD and causes the robot to carry out a spot welding operation. 
The shell routine consists of two different lists of robot instructions, that is, one forward list 22, and one back- 
ward list 23. For the program executor to be able to find the forward list and the backward list, the forward list 
always starts with the word FORWARD and the backward list with the word BACKWARD. These words con- 
stitute reserved words in the robot language and may not be used in any other connection. 

40 Figure 4 shows, by way of a flow diagram, an example of the appearance of that part of the program exe- 

cutor which executes the shell routine in Figure 3. When the program executor arrives atthe instruction SWELD 
in the user program, it carries out in block 31 a jump to the shell routine SWELD which is stored in the program 
storage. If the program unit is set at backward, the instructions in the backward list are executed, block 32, 
otherwise the forward list is executed, block 33. 

45 Figure 5 shows an example of a user program 41 which comprises the shell instruction SWELD and the 

fixed robot instructions R11, RI2 and RI3. When executing the fixed robot instructions, the corresponding fixed 
routines 42, 43 and 44 are called. When executing the shell instruction, the shell routine 45 is called, whereupon 
the backward list or the forward list is executed depending on whether the programming unit is set at forward 
or backward. The instructions in the shell routine consist of fixed robot instructions and when these are exe- 

50 cuted, fixed routines are called, for example 46, 47 and 48. 

In the above examples the shell routine comprises a set of robot instructions where all the robot instruc- 
tions are fixed instructions. A robot instruction in a shell routine may also consist of a shell instruction. A shell 
routine comprises a set of robot instructions, wherein a robot instructions may be either a fixed instruction or 
a shell instruction. 

55 The forward list and the backward list may also contain logic clauses such as "if-then-else" clauses and 

"while" clauses. 

The names of the forward and backward lists (FORWARD, BACKWARD) are there to distinguish between 
the two lists. In another embodiment, the name of the forward list (FORWARD) may be omitted. Unless back- 
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ward execution has been requested, the forward list is always executed. 

The control system described above comprises a compiler for translating the shell routines into an inter- 
mediate code or a machine code. In another embodiment, the compiler may be omitted, and then the executor 
instead carries out shell routines and user programs directly. 

5 The shell routine in this embodiment has two attributes, but it is also possible to have more attributes. 

In certain cases it is an advantage for the robot supplier to write those robot instructions which are to be 
supplied to the robot user in the form of shell instructions. Such a shell instruction may then be provided with 
an attribute, a so-called system attribute, which means that the module is stored more permanently in order 
to prevent unintentional erasure. Changes of the shell routine may then only be made by the robot manufac- 

10 turer, or by a person authorized by the robot manufacturer. This attribute is stronger than the "view-only" at- 
tribute, which may, for example, be set by the program preparer to prevent the operator from making changes 
in the program. 

In another embodiment a plurality of shell routines may be brought together into one module with attributes 
common to these shell routines. Figure 6 shows an example of a module 50 with three attributes, "view-only" 
15 (VO) 21a, "no-step-in" (NSI) 21b and system attribute (SA) 21c. The module comprises three shell routines 
20 which are all associated with the common attributes. 



Claims 

20 

1 . A control system for an industrial robot wherein the control system comprises a program storage (11 ) for 
storage of a user program consisting of a series of robot instructions, and a program executor (1 3) adapt- 
ed, when running the user program, to execute the stored robot instructions, characterized in that at least 
one of the robot instructions is arranged as a so-called shell instruction, which constitutes a call to a so- 

25 called shell routine (20), the shell routine being associated with a number of optional attributes, and that 

the shell routine comprises 

- a forward list (22) comprising a first set of robot instructions; and 

- a backward list (23) comprising a second set of robot instructions, 

and that the program executor (13) is adapted, for forward running of a user program comprising shell 
30 instructions, to execute the shell instructions in accordance with the forward list and, for running the user 

program backwards, to execute the shell instructions in accordance with the backward list 

2. A control system according to claim 1 , characterized in that the shell routine comprises an attribute (VO, 
SA) which indicates that it may be read, but is blocked for changes. 

35 

3. A control system according to claims 1 and 2, characterized in that the shell routine comprises an attribute 
(NSI) which indicates that when a shell instruction is used in a user program, the shell routine is concealed 
to the user. 

40 4. A control system according to any of the preceding claims, characterized in that a plurality of shell rou- 
tines are associated with the same attributes. 

5. A method according for controlling an industrial robot which comprises a user program consisting of a ser- 
ies of robot instructions, and a program executor (13), 
45 characterized in that 

a) at least one robot instruction is created in the form of a shell instruction and a shell routine corre- 
sponding to the shell instruction, the shell routine being associated with a number of optional attributes, 
wherein the shell routine comprises 

- a forward list (22) comprising a first set of robot instructions; and 
so - a backward list (23) comprising a second set of robot instructions, 

b) the shell instruction is used for producing the user program, 

c) the user program is executed by the program executor, and when running forwards the shell instruc- 
tion is carried out in accordance with the forward list, and when running backwards the shell instruction 
is carried out in accordance with the backward list 
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Fig. 5 
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